Optimization of Primality Testing Methods by GPU Evolutionary Search
نویسنده
چکیده
Modern fast primality testing uses a combination of Strong Probable Prime (SPRP) rejection tests. We find more powerful combinations by intensive search of the vast domain of SPRP test configurations. Evolutionary guidance using previous promising results boosts search speed. We implement the entire search on the GPU with the CUDA programming language resulting in 65-time speedup over a CPU search. This project has already found a test an order of magnitude more powerful than the best previously known. 1 Primality Tests by Strong Probable Primes How do you determine if a given n is prime? Countless practical and diverse problems ask this, ranging from hash table design, cryptography, Rabin-Karp string searching, and randomized task scheduling. Simple trial division with the integers from 2 to √ n is a classic and well known method, but as O( √ n), faster methods are much better for n larger than 5000 or so. In practice the fastest computational method for larger n is Strong Probable Prime testing. By Fermat’s Little Theorem, for an odd prime n, the number 1 has only two square roots modulo n, 1 and n − 1. So for prime n and any integer a > 1 the square root of a mod n is 1 or n − 1. We can use this fact to identify many composite numbers by merely choosing any a, substituting n into the equation and checking the modular remainder. If the remainder is not 1 or n-1, we can stop since we now know n is composite. However this does not yet guarantee that all passed values are prime. We can make the test even better at quickly identifying composites by noting that if (n− 1)/2 is even, we can take another square root and get yet another rejection test. We remove out the factors of 2 to form n−1 = d·2 where d is odd and s is non negative. n is called a strong probable prime base a (an a-SPRP) if either a ≡ 1 mod n or (a)r ≡ n − 1 mod n for some non-negative r less than s. All integers n > 1 which fail this test are composites. Integers that pass probably are primes. For a = 2, the 2-SPRP test is rarely incorrect, and in fact the first composite n undetected by the 2SPRP test is n = 2047 = 23 · 89. The first missed by the 3-SPRP test is n = 121 = 11 · 11. The first miss by the 5-SPRP test is n = 781 = 11 · 71. SPRP tests are very fast in practice using standard methods for modular powers (also used in RSA encryption). The computation is O(log n) and is independent of the choice of a. Since an SPRP test can miss an occasional composite, testing can be repeated with two or more independent SPRP bases to give better and better confidence that a value repeatedly passed is indeed prime. Miller and Rabin made this a practical guaranteed primality test by finding an explicit pair of SPRP bases, which combined are pre-verified to correctly identify primality for as large n as possible. ∗e-mail: [email protected] 1Much of the mathematical description for this section draws from the excellent Prime Pages website at primes.utm.edu. This website also inspired this work when I was searching for an isPrime() function. For example, the smallest composite n which is both a 2-SPRP and a 3-SPRP is 1,373,653. This immediately forms a guaranteed primality test for any n < 1, 373, 653. Such a (now deterministic) test is known as the Miller Rabin primality test. Other researchers realized this was a very useful tool in practice, and significant attempts were made to discover the best values of bases a to maximize primality testing ranges beyond 1,373,653. In 1980 Carl Pomerance explored the SPRP tests and shared the first high speed prime testing code, used extensively for years. All tests using two SPRP evaluations require the same amount of computation, so interest grew in discovering the SPRP bases that maximize the range of n that the tests apply to. In 1993, a paper by Gerhard Jaeschke showed that primes from the much wider range of up to 9,080,191 could be classified with just two tests (a 31-SPRP and 73-SPRP). In 2004 Zhang and Tang improved the theory of the search domain. Finally in 2005, Greathouse and Livingstone used computation on several computers for a period of months to find the currently best known published results: a combination of 2-SPRP and 299417SPRP gives guaranteed primality results for all n < 19, 471, 033. 2 Searching for better SPRP combinations The speed of SPRP tests do not vary by a, so it is completely acceptable to choose whatever values work best. A practical limit keeps a < 2 just for ease of representation and use of native processor math operations. We could try to find a test with an even higher n limit by picking two a values and testing every composite integer until both SPRP tests fail and hoping we exceed our previous best known n. Unfortunately while the SPRP test is very fast, we need to evaluate the test for millions of composite value to determine the minimum composite which fails, and hope that first failure is larger than the best known test’s range. Such a brute force algorithm is straightforward to implement but on a CPU requires several seconds to test a pair of SPRP bases over the several million test values. If we restrict a < 2 for efficiency, there are 2 possible pairs of bases to choose from, far too many to explore exhaustively. The distribution and behavior of prime number distribution is a huge topic in number theory, and the behavior of SPRP composite failures is similarly chaotic. The best theoretical analysis has been by Zhang and Tang, who found limits on minimum n but no useful guidance on how to find sets of tests which are especially efficient. Therefore, finding better SPRP tests is a task of raw power and empirical heuristics. Several obvious search strategies were initially explored. One was a simple brute force enumeration of pairs in a deterministic order based on minimizing their sum. Another enumerated (2,x) for all x < 2, then proceeded to (3,x) and so on. A third randomly sampled the whole domain. However, the most effective algorithm found was a simple progressive evolutionary test, subjecting test bases to a successively more difficult set of challenges and allowing only the best-performing to continue. The most promising base values pass each test and there2Developer of the factoring method to crack RSA-129 decryption! 3Errors have been found in some of Greathouse’s higher order results, but his SPRP tests for two bases are correct. fore even more computation is invested in them for another round of search. This strategy performed exceedingly well, perhaps because the amount of effort spent on each value is proportional to how well it proved itself on previous rounds. The search algorithm starts by picking a random initial base value. The value is exhaustively tested as a partner with all values from 2 to 10,000,000, taking approximately 10 seconds on a NVidia GTX280. The fitness measure to maximize is the value of the first composite n which the pair of values both misidentify as a prime. The best result of that search is tested against a predetermined threshold to allow only about 30% of test values to pass to a more intensive second round of 25M additional tests. This cycle of survival-of-the-fittest continues with five rounds, each with an increasing number of tests but also an increasingly difficult fitness threshold to cross. The final state is an ultimate exhaustive test of all 2 − 1 partner values. Less than 0.1% of test values are fit enough to reach the final exhaustive stage. 3 GPU Implementation GPUs have enormous computational horsepower compared to CPUs, making them attractive for a compute intensive task like SPRP searching. Even though GPUs are actually faster at floating point than integer, the vast number of GPU subprocessors makes up for any weakness. We implement the search using the CUDA programming enviroment for NVidia GPUs. The very C-like language made prototyping and implementation straightforward. The SPRP’s evaluation is quite straightforward as a classic modular power computation, very similar to one used for RSA encryption. We have an advantage in that our values of a and n are under 2 and we can use many native CPU math operations instead of using a generalized “bigint” library. Most of the SPRP algorithm’s time is simply spent doing modular powers, such as a mod c. This is a classic computer science homework problem, and it is often solved by reduction by noting that if b is even then a mod c = (a mod c) mod c, and if b is odd, then a mod c = a · (a mod c) mod c. The above reduction now just needs a way to compute a · b mod c, which is complicated by the fact that a · b can easily overflow a 32bit integer. Another reduction of the same style solves the problem. If b is even, then a · b mod c = 2a · b 2 mod c and if b is odd, then a · b mod c = a+2a · b b 2 c mod c. The final subproblem of simple modular addition of a + b mod c is an easy addition and single overflow test. Unrolling the reductions one step for even more efficient computation is another trick known as Montgomery Reduction. This uses a small table of precomputed values of 1, a, a, a mod c to halve the number of steps needed. In practice we are able to significantly benefit from such a table lookup. An interesting implementation detail involves the use of CUDA shared memory for the lookup table. We give each thread in a block “ownership” of 4 words in shared memory for its own lookup table. These table entries are spaced 16 words apart in order to prevent a subtle memory efficiency problem known as bank conficts. By giving each thread its scratch memory spaced by 16, each thread has its own bank of shared memory and thus does not interfere with other thread’s lookups. This subtle implementation detail improved performance 20%. The CUDA kernel is designed to assign every thread one independent pair to test. A thread checks its pair, proceeding until it finds the first misclassified composite. We want kernel launches to remain in the millisecond range to keep the OS interactive. The compute proceeds by evaluating only a few thousand tests and checkpointing its progress (needing to store only two words) to resume in the next launch. Thus the continuous GPU search has little OS impact, allowing the compute to run unobtrusively for days or weeks. The pause-and-restart design also allowed for automatic load balancing. If a thread is unlucky and tests a poor candidate, it can finish its work much earlier than another thread who needs to test more values, leaving the early thread idle. A simple test at kernel launch identifies idle threads and has them steal work from threads with work remaining. This load balancing was easy to implement by merely rearranging the saved work status storage. Load rebalancing boosted search throughput by 60% by retasking these idle threads. The design of CUDA automatically handles block-wise work assignment, so the software does not know nor care if the GPU is a small 16 core or large 240 core GPU; speed simply scales completely linearly with SP count. All computation is done entirely on the GPU, leaving the CPU idle except as a polling kernel host. The simple polling loop keeps the CPU loaded by about 10%. This could likely be improved by queuing multiple asynchonous kernel launches. The original expectation was to have the CPU simultaneously run searches, but the raw speed of the GPU search makes any CPU contribution negligable and merely a distraction. Since the evolutionary search begins with a random base choice, it is embarassingly trivial to support multi-GPU and even multimachine evaluation. Each GPU uses its own random seed and each follows its own independent randomized evolution. Results don’t need to be combined or intercommunicated except to occasionally manually note which GPU or machine has the best results so far. Unlike many distributed computations, there is little need to avoid work duplication given the huge search space, and the progressive results from each device is just a simple pair of numbers: the best results that GPU has found so far.
منابع مشابه
Using composite ranking to select the most appropriate Multi-Criteria Decision Making (MCDM) method in the optimal operation of the Dam reservoir
In this study, the performance of the algorithms of whale, Differential evolutionary, crow search, and Gray Wolf optimization were evaluated to operate the Golestan Dam reservoir with the objective function of meeting downstream water needs. Also, after defining the objective function and its constraints, the convergence degree of the algorithms was compared with each other and with the absolut...
متن کاملRelational Databases Query Optimization using Hybrid Evolutionary Algorithm
Optimizing the database queries is one of hard research problems. Exhaustive search techniques like dynamic programming is suitable for queries with a few relations, but by increasing the number of relations in query, much use of memory and processing is needed, and the use of these methods is not suitable, so we have to use random and evolutionary methods. The use of evolutionary methods, beca...
متن کاملOptimization in Uncertain and Complex Dynamic Environments with Evolutionary Methods
In the real world, many of the optimization issues are dynamic, uncertain, and complex in which the objective function or constraints can be changed over time. Consequently, the optimum of these issues is changed nonlinearly. Therefore, the optimization algorithms not only should search the global optimum value in the space but also should follow the path of optimal change in dynamic environmen...
متن کاملA Comprehensive Survey on Various Evolutionary Algorithms on GPU
This paper presents a comprehensive survey on parallelizing computations involved in optimization problem on Graphics Processing Unit (GPU) using CUDA (Compute Unified Design Architecture). GPU have multithread cores with high memory bandwidth which allow for greater ease of use and also more radially support a layer body of applications. Many researchers have reported significant speedups with...
متن کاملSoft Computing Methods based on Fuzzy, Evolutionary and Swarm Intelligence for Analysis of Digital Mammography Images for Diagnosis of Breast Tumors
Soft computing models based on intelligent fuzzy systems have the capability of managing uncertainty in the image based practices of disease. Analysis of the breast tumors and their classification is critical for early diagnosis of breast cancer as a common cancer with a high mortality rate between women all around the world. Soft computing models based on fuzzy and evolutionary algorithms play...
متن کامل